<?php  if (!defined('BASEPATH')) exit('No direct script access allowed');
if ( ! function_exists('auth_img'))
{
    function auth_img()
    {
	
	
        $img_height=100;    //先定义图片的长、宽
        $img_width=36;
        //srand(microtime() * 100000);//PHP420后，srand不是必须的
        $nmsg='';
        for($Tmpa=0;$Tmpa<4;$Tmpa++){
            $nmsg.=strtoupper(dechex(rand(0,15)));
        }//by sports98
        $_SESSION['authcode'] = $nmsg;
        $aimg = imageCreate($img_height,$img_width);    //生成图片
        ImageColorAllocate($aimg, 255,255,255);            //图片底色，ImageColorAllocate第1次定义颜色PHP就认为是底色了
        $black = ImageColorAllocate($aimg, 0,0,0);        //定义需要的黑色
        ImageRectangle($aimg,0,0,$img_height-1,$img_width-1,$black);//先成一黑色的矩形把图片包围
        //下面该生成雪花背景了，其实就是在图片上生成一些符号
        for ($i=1; $i<=100; $i++) {    //先用100个做测试
            imageString($aimg,1,mt_rand(1,$img_height),mt_rand(1,$img_width),"*",imageColorAllocate($aimg,mt_rand(200,255),mt_rand(200,255),mt_rand(200,255)));
        }
        //上面生成了背景，现在就该把已经生成的随机数放上来了。道理和上面差不多，随机数1个1个地放，同时让他们的位置、大小、颜色都用成随机数~~
        //为了区别于背景，这里的颜色不超过200，上面的不小于200
        for ($i=0;$i<strlen($_SESSION['authcode']);$i++){
            imageString($aimg, mt_rand(3,5),$i*$img_height/4+mt_rand(1,10),mt_rand(1,$img_width/2), $_SESSION['authcode'][$i],imageColorAllocate($aimg,mt_rand(0,100),mt_rand(0,150),mt_rand(0,200)));
        }
        Header("Content-type: image/png");    //告诉浏览器，下面的数据是图片，而不要按文字显示
        ImagePng($aimg);                    //生成png格式。。。嘿嘿效果蛮像回事的嘛。。。
        ImageDestroy($aimg);
    }       
}
